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INTRODUCTION TO CPU INSTRUCTIONS 



INSTRUCTION FORMAT 



Each System Ten* computer instruction is 10 characters long. 

Each instruction must be positioned so that the address of 
the leftmost character is a multiple of 10 (e.g., 0, 10, 
20, 30.... etc.). The first few characters of an 
instruction as they appear in memory have the following 
format : 



CHARACTER 



BIT 





1 




2 




3 


F3 1 


LA 


F2 1 


A3 


Fl 1 


A2 



754321 754321 754321 



Figure 1 Instruction Format - Sequential 



*A trademark of the Singer Company. 
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Introduction to CPU Instructions 



A more useful representation of instruction format is 
achieved by giving a vertical orientation to the bits of a 
character as is done below. 



Operation Code 






1 


2 


3 


4 


5 


6 


7 


8 


9 


BIT 


F3 


F2 


Fl 


FO 


AC 


IA1 


IAO 


IB1 


I BO 


BC 


7 


1 


1 


1 


1 


1 


1 


1 


1 


1 


1 


5 






















4 


LA 


A3 


A2 


Al 


AO 


LB 


B3 


B2 


Bl 


BO 


3 






















2 






















1 



Figure 2 Instruction Format - Parallel Blocking 



In this representation functionally related bits such as F3 
- FO also have a close spatial relationship. 



The operation code of an instruction is specified by the 
four bit binary number F = F3F2F1F0, e.g., an ADD 
instruction is indicated when F=0100 and a COMPARE when 
F = 1110. 



Address Fields 



Each instruction contains two address fields A and B. 
These are generally used to specify the addresses of the 
two operands which participate in the operation specified 
by F. Each address is a four digit decimal number between 
0000 and 9999 inclusive. 

The A-address is given by A3A2A1A0, the numeric portion 
(bits 1 thru 4) of characters 1 thru 4. 

The B-address is given by B3B2B1B0, the numeric portion of 
characters 6 thru 9. 
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Introduction to CPU Instructions 



Addressing Mode 



An instruction address may refer to a location in COMMON or 
in partition. 

AC = 1 Means the A address refers to a location in COMMON. 
AC = Means the A address refers to a location in 
partition. 

BC = 1 Means the B address refers to a location in COMMON. 
BC = Means the B address refers to a location in 
partition . 



Indexing 



In most instructions both the A and B address may be 
indexed. Index register selection for the A address is 
determined by IA, and for the B address by IB, according to 
the table below: 






NO INDEXING 
INDEX REGISTER ONE 
INDEX REGISTER TWO 
INDEX REGISTER THREE 

Index Addresses 




IA1 
IB! 


IAO 
IBO 











1 


1 





1 


1 




Table 1 
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Operand Lengths 



Operand lengths are explicitly defined using LA and LB, the 
numeric portion of characters and 5 respectively. 
Certain instructions use LA and LB differently as will be 
discussed later. 

LA— -length, in number of characters of the Operand-A. 

LB--length, in number of characters of the Operand-B. 



4 CPU Instructions Reference Manual 



4/73 



ADD INSTRUCTION 



ADD INSTRUCTION 



The Add instruction adds the numeric portions of two 
operands algebraically. The sum replaces the second 
operand and leaves the first operand unchanged if the 
fields do not overlap. 



INSTRUCTION FIELDS 

Machine Operation Code 

I F Binary 100 (4 ) 

Address Specification 



A Address of the leftmost position of Operand-A. 

B Address of the leftmost position of Operand-B. 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB--Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is 0, A is address in controlling partition. 

If AC is 1, A is address in Common. 

BC--If BC is 0, B is address in controlling partition. 

If BC is 1, B is address in Common. 



LA--Length of Operand-A. 
LB--Length of Operand-B. 
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Add Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2, or 3, the corresponding index register is 

added to A to determine the effective address of Operand-A. 

If AC is 1, the effective address lies in Common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, the corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1 , the effective address lies in Common. 



If LA is 0, the length of Operand-A is 10 characters. 

If LA is 1 thru 9, the length of Operand-A is 1 thru 9 
characters . 

If LB is 0, the length of Operand-B is 10 characters. 

If LB is 1 thru 9, the length of Operand-B is 1 thru 9 
characters . 



OPERATION 

General Description 



The add operation proceeds from right to left starting with 
the rightmost characters of Operand-A and Operand-B. 
Character by character, the algebraic sum is developed in 
Operand-B . 

If Operand-A is shorter than Operand-B, the operation 
proceeds normally until Operand-A is exhausted. After 
that, the process continues in similar fashion except that 
a zero character is automatically substituted every time 
the adding logic calls for a character from Operand-A. In 
effect, Operand-A is given enough preceding zeros to make 
it the same length as Operand-B. 

If Operand-A is longer than Operand-B, addition stops after 
the leftmost position in Operand-B has been added. The 
remaining positions in Operand-A are ignored, and do not 
affect the sum or the Condition Code. 
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Add Instruction 



The algebraic sign of the sum is placed in bit-7 of the 
rightmost position of Operand-B, and bit-5 is turned ON. 
Except for the rightmost character, the other zone bits of 
Operand-B are unchanged. Operand-A is unchanged by the add 
operation. 

If the sum exceeds the capacity of Operand-B, a carry-to- 
the-left from the leftmost position does not occur. 
Condition Code 4 is set to indicate the overflow. 



Condition Codes 



After completion of the Add instruction 

1 = Negative, non-zero sum. 

2 = Zero sum. 

3 = Positive, non-zero sum. 

4 = Overflow. 



Execution Time (T) in Microseconds 



T=42.2 + 3.3 (LA) + 10.0 (LB) + TIX + TOD, if LA is equal 
to or less than LB. 

T=42.2 + 11 (LA) + 12.2 (LB) + TIX + TOD, if LA is 
greater than LB. 

Key: TIX = 0.0,- if IA and IB are both zero. 

TIX =58.9, if IA and IB are both non-zero. 
TIX =31.1, if IA or IB is non-zero. 

TOD = 0.0, if an overdraft does not occur. 
TOD =10.0 (LB), if an overdraft occurs. 

An overdraft will always occur when the absolute 
value of Operand-A exceeds the absolute value of 
Operand-B and they have unlike signs. 



PROGRAMMING HINTS 

Overlapped Operands 



In case of overlapped operands, the result is unspecified 
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BRANCH INSTRUCTION 



The Bra 

sequenti 

executed 

upon th 

depend u 

service 

passes c 

return 

Executio 

Conditio 



nch instruction permits departure from the 
al path by which instructions are normally 
Branching can be unconditional, it can depend- 
e current status of the Condition Code, or it can 
pon signals from Input/Output devices requesting 
from the CPU. A variant of the Branch instruction 
ontrol to a subroutine after first setting the 
address at which the main program will be resumed, 
n of the Branch instruction does not alter the 
n Code . 



INSTRUCTION FIELDS 

Machine Operation Code 

I F Binary 1011 (11). 

Address Specification 

A Address -A 

B Address-B 

Indexing Specification 

IA--Ignored. Branch instructions are not indexed. 

IB--Ignored. Branch instructions are not indexed. 

Common Partition Specification 

AC--If AC is 0, A is an address in controlling partition, 
If AC is 1 , A is an address in Common. 

BC--If BC is 0, B is an address in controlling partition 
If BC is 1, B is an address in Common. 



Variant Specification 



LA — A digit 0-9. 
LB--A digit 0-6, 8, 9. 
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OPERATION 

Order of Presentation 



The Branch instruction consists of several variants. The 
LA and LB instruction fields determine which variant is 
executed. "Link" (variant 6) and "Branch on Service 
Request" (variant 7) require that the entire instruction be 
decoded. These variants are discussed later under separate 
headings. The other variants are decoded and executed a 
half instruction at a time and are most conveniently 
discussed as a group in the next paragraph. 



Variants 0, 1, 2, 3, 4, 5, 8, 9 



The first five characters of the instruction are fetched. 
LA is examined. If a branch is required, control passes to 
Address-A, and the right half of the instruction is 
ignored. If a branch is not required in the left half of 
the instruction, the right half is fetched. LB is 
examined. If a branch is required, control passes to 
Address-B. If a branch is not required, execution 
continues with the next sequential instruction. 

The following table shows the values which LA and LB may 
assume. Beside each variant number is the meaning applied 
by the ACU . Variant 6 and variant 7 are purposely omitted. 
They are discussed under "Link" and "Branch on Service 
Request" . 

Variant Do not branch ( "no operation" ) . 

Variant 1 Branch if Condition Code is 1. 

Variant 2 Branch if Condition Code is 2. 

Variant 3 Branch if Condition Code is 3. 

Variant 4 Branch if Condition Code is 4. 

Variant 5 Branch, unconditionally. 

Variant 8 Branch and switch partitions, unconditionally. 

Variant 9 Do not branch ("no operation"). 
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Branch Instruction 



Partition Switching 



If a Branch instruction does not require a branch, 
execution simply continues with the next sequential 
instruction. 



If the host partition has been in continuo 
more than 37.5 milliseconds when a branch 
branch is taken but the execution of the in 
branch address is postponed and control pas 
partition. When control returns, executio 
branch address. If the branch is caused 
("Branch and switch, unconditionally"), the 
but the execution of the instruction at th 
is postponed and control passes to the next 
though 37.5 milliseconds have not elapsed. 



us control for 
is required, the 
struction at the 
ses to the next 
n resumes at the 
by variant 8 

branch is taken 
e branch address 

partition even 



LINK - BRANCH VARIANT 6 



LA — Must be 6. 

LB--May be thru 5 , 8 , or 9 . 

If LB is or 9, no link occurs; control simply passes 
to the next instruction. 

If LB is 1-4, the corresponding Condition Code is 
tested. If the specified Condition Code is ON, the 
link operation is performed. Otherwise, control simply 
passes to the next instruction. 



If LB is 5 or i 
unconditionally 



the link operation is performed, 



Return Address/Start Address 



The address of the next instruction (return address) is 
inserted into the numerical portion of the four position 
field starting at Address-A. The zone portions of the 
three left character positions are unchanged. Bit-5 of the 
rightmost position is set to 1. Bit-7 is set to 1 if the 
return address is in common; it is set to if the return 
address is in partition. Control then passes to Address-B 
( start address ) . 



BRANCH ON SERVICE REQUEST - BRANCH VARIANT 7 



LA — Must be 7. 

LB — Must be or 9. 
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Branch Instruction 



INSTRUCTION 


cc = 1 : 


CC = 2 


CC = 3 


CC = 4 


(a]dd 


MINUS 


ZERO 


PLUS 


OVERFLOW 


Dranch [c]onditional 


















(CJOMPARE 


A IS LESS 


EQUAL 


A IS GREATER 


A NOT LESS 


|5]lVIDE 


MINUS 


ZERO 


PLUS 


OVERFLOW 


Hdit 


MINUS 


ZERO 


PLUS 






EXCHANGE 




2 ALWAYS SET 












gORM (nJuMERIC FIELD 


MINUS 


ZERO 


PLUS 


OVERFLOW 


[m]OVE JCJHARACTER 




2 ALWAYS SET 












[m]ove (n]umeric 




2 ALWAYS SET 












[m]ultiply 


MINUS 


ZERO 


PLUS 






[r]ead 


ERROR 


NORMAL 


FLAG 


FAULT 


SUBTRACT 


MINUS 


ZERO 


PLUS 


OVERFLOW 


[w]rite 


ERROR 


NORMAL 


FLAG 


FAULT 



Table 2 Condition Code Settings 
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Branch Instruction 



Operation - Storing Device Number 



Each 

atta 

for 

poll 

and 

exec 

Requ 

port 

Cont 

next 

was 



IOC 
ched to 

servic 
ing for 

the d 
utes "B 
est" c 
ion of 
rol the 
highe 
9) . 



cont 
it to 
e. If 
servi 
evice 
ranch 
auses 
the ch 
n pass 
r dev 



inual 

see 

the 

ce re 

numb 

on Se 

the 
aract 
es to 
ice n 



ly poll 
if a dev 
IOC enco 
quests i 
er is he 
rvice Re 

counter 
er posit 

Address 
umber (o 



s the input 
ice has signa 
unters such a 
s temporaril 
Id in a count 
quest" . "Bra 
to be store 
ion pointed t 
-B. Polling 
r , if the r 



/output devices 
lied a request 
signal, further 
y discontinued, 
er until the CPU 
nch on Service 
d in the numeric 
o by Address-A. 
resumes with the 
equesting device 



If the IOC is holding no such request for service, "Branch 
on Service Request" has no effect. Execution continues 
with the next sequential instruction. 



Condition Codes 



I Condition Codes are unchanged by the Branch instruction 

Execution Time (T) in Microseconds 

T=37.8 for no branch. 

T=27.8 for branch to Address-A. 

T=44.4 for branch to Address-B (except variants 6,7). 

T=75.5 for "Link" (variant 6). 

T=51.1 for "Branch on Service Request" (variant 7). 



PROGRAMMING HINTS 



Since each instruction (with the exception of Branch) sets 
the condition code, it is necessary to test the condition 
code immediately after the performance of an operation. 
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Branch Instruction 
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COMPARE INSTRUCTION 



The Compare instruction compares two fields and sets the 
Condition Code to indicate the relation between them. 



INSTRUCTION FIELDS 

Machine Operation Code 

I F Binary 1110 ( 14) . 

Address Specification 

A Address of the leftmost position of Operand-A. 

B Address of the leftmost position of Operand-B. 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB--Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is 0, A is address in controlling partition. 

If AC is 1, A is address in Common. 

BC--If BC is 0, B is address in controlling partition. 

If BC is 1, B is address in Common. 



LA--Tens position of length of both Operand-A and Operand- 
B. 

LB--Units position of length of both Operand-A and Operand- 
B. 
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Compare Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2, or 3, the corresponding index register is 

added to A to determine the effective address of Operand-A. 

If AC is 1, the effective address lies in Common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, then corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1, the effective address lies in Common. 



Operand-A and Operand-B are equal in length. 

10LA + LB = Lengths of operands for the Compare 

instruction. 

If 10LA + LB =00, 100 is the length of the operands. 



OPERATION 

General Description 



The compare operation proceeds from left to right starting 
with the leftmost character of Operand-A and Operand-B. 
Character by character, the values of Operand-A and 
Operand-B are compared until a difference is found or the 
rightmost position has been compared. 

When the characters differ, Condition Code 1, or 3 and 4 is 
set ON (indicating that Operand-A is smaller or larger than 
Operand-B), and the operation is complete. 

If the characters are identical, and there are more 
positions to be compared, the comparison is repeated for 
the next position on the right. 
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Compare Instruction 



When the characters are identical and there are no more 
positions to be compared, Condition Codes 2 and 4 are set 
ON. 

Operand-A and Operand-B are unchanged by the compare 

operation. 

When Condition Code 3 or 2 is set ON, Condition 4 is also 
set ON. 



Condition Codes: 



1, if Operand-A is less than Operand-B. 

2 and 4, if Operand-A and Operand-B are identical 

3 and 4, if Operand-A is greater than Operand-B. 



Execution Time (T) is Microseconds 



T=40.0 + 7.78 (10LA + LB) + TIX, if the operands are 

identical . 

T=48.9 + 7.78 (Y) + TIX, if the operands differ. 

Key: Y = the number of equal comparisons. 
TIX = 0.0, if IA and IB are both zero. 
TIX =58.9, if IA and IB are both non-zero. 
TIX =31.1, if IA or IB is non-zero. 



PROGRAMMING HINTS 



Character Values 



The reader is referred to the Table 3 entitled 
"Characters Arranged in Sequence of Value." In the first 
column under "Character Code" are the internal codes of 
each character used in the Model 20 Processor. In the 
second column under "Character" are the corresponding 
characters. The table can be used to resolve uncertainties 
as to which of two characters the Compare instruction 
considers to be the larger. A character is considered 
greater than the other characters which precede it in the 
table. It is less than those which follow it. 



Sorting 



A principal use of the Compare instruction is in sorting 
data. The programmer is reminded that the units position 
of a negative numeric field is coded with zone bit-7 ON . 
(If the digit were positive, bit-7 would be OFF.) Thus, in 
a compare operation, a negative digit is of greater value 
than any positive digit. 
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Compare Instruction 



Character Code 


Character 


b 7 


b b 


b 4 


b 3 


b 2 


b l 






















SP 


Space 



















! 


Exclamation Point 




















Quotation Mark 


u 















# 


Number Sign 











1 






$ 


Dollar Sign 











1 






% 


Percent 











1 






8, 


Ampersand 











1 








Prime, Apostrophe 

















( 


Left Parenthesis 

















) 


Right Parenthesis 

















* 


Asterisk 

















+ 


Plus Sign 










1 








Conma 










1 






- 


Minus Sign, Hyphen 










1 








Period, Decimal Point 










1 






/ 


Slash 




















Zero 

















1 


One 

















2 


Two 

















3 


Three 










1 






4 


Four 










1 






5 


Five 










1 






6 


Six 










1 






7 


Seven 
















8 


Eight 
















9 


Nine 


















Colon 


















Semicolon 









1 






< 


Less-than Sign 









1 






= 


Equal Sign 









1 






> 


Greater-than Sign 









1 






? 


Question Mark 




















At Sign 

















A 



















B 



















C 












1 






D 












1 






E 












1 






F 












1 






G 


















H 


















I 


















J 


















K 











1 






L 











1 






M 











1 






N 











1 

























P 


















Q 


















R 


















S 











1 






T 











1 






U 











1 






V 











1 






W 

















X 

















Y 


















Z 



















Opening Bracket 








1 







\ 


Reverse Slant 








1 






) 


Closing Bracket 








1 




u 




Circumflex 








1 









Onderline 



CHARACTERS ARRANGER 
IN SEQUENCE OF VALUE 



Table 3 Characters Arranged in Sequence of Value 
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DIVIDE INSTRUCTION 



The Divide instruction computes the algebraic quotient (and 
remainder) of two operands. 



INSTRUCTION FIELDS 

Machine Operation Code 

I F Binary 0101 ( 5 ) 

Address Specification 



A Address of the leftmost position of Operand-A. 

B Address of the leftmost position of Operand-B (dividend) 

Address of the quotient. 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB--Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is 0, A is an address in controlling partition 

If AC is 1 , A is an address in Common. 

BC--If BC is 0, B is an address in controlling partition 

If BC is 1, B is an address in Common. 



LA--Length of Operand-A (divisor). 

LB--Length of the quotient. 

LA + LB--Length of Operand-B (dividend) 
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Divide Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2, or 3, the corresponding index register is 

added to A to determine the effective address of Operand-A, 

If AC is 1, the effective address lies in Common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, the corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1, the effective address lies in Common. 



If LA is 0, the length of Operand-A is 10 characters. 

If LA is 1 thru 9, the length of Operand-A is 1 thru 9 
characters . 

If LB is 0, the length of Quotient is 10 characters. 

If LB is 1 thru 9, the length of Quotient is 1 thru 9 
characters . 

LA + LB is the length of Operand-B (dividend). 



OPERATION 

General Description 



Operand-A is the divisor. 

The dividend begins at the B address and contains LB + 
positions . 



LA 



At the end of the operation, the guotient occupies the 
leftmost LB positions of the dividend field, and the 
remainder occupies the rightmost LA positions of the 
dividend field. 

If the divisor and the dividend differ in sign, bit-7 of 
the quotient is turned ON to indicate a negative quotient. 
If the signs are alike, bit-7 is turned OFF to indicate a 
positive quotient. Bit-5 is turned ON for all positions of 
the quotient; bit-7 is turned OFF for all positions except 
the rightmost. 
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Process 



Divide Instruction 



Bit-7 of the rightmost position of the remainder is 
unchanged. It continues to show the sign of the dividend. 
Bit-5 is set to 1 . The zone bits of the other positions in 
the remainder are unchanged. 



An internal counter is set to zero. It will count the 
number of times the divisor is subtracted from a subfield- 
of -the-dividend . The subfield length is one greater than 
the length of the divisor. The first subfield chosen is at 
the extreme left of the dividend. 



The divisor is 
until the value 
divisor. Each 
count exceeds 9 
overflow) , and 
does not exceed 
divisor, the c 
the subfield whe 
quotient. The 
to the next subf 
in the dividen 
quotient. After 
position, etc. 
subfield in the 



repeatedly subtracted from the subfield 
of the subfield is less than that of the 
subtraction increments the counter. If the 
, Condition Code 4 is set (indicating 

the operation is abandoned. If the count 
9, and the subfield value is less than the 
ount is stored in the leftmost position of 
re it is also the leftmost position of the 

counter is cleared, and the process shifts 
ield (one character position to the right 
d) to develop the second position of the 

this, another shift to develop the third 
The operation ends after the rightmost 
dividend is processed in this fashion. 



Condition Codes 



After completion of the Divide instruction 

1 = Negative, non-zero quotient. 

2 = Zero quotient. 

3 = Positive, non-zero quotient. 

4 = Overflow . 



Execution Time (T) in Microseconds 



T=46.67 + 1.11 (LA) + 26.67 (LB) + 22.22 (LA) (LB) + 
(10.0 + 11.1 (LA) ) (S) + TIX. 

Key: TIX = 0.0, if IA and IB are both zero. 

TIX =58.9, if IA and IB are both non-zero. 
TIX =31.1, if IA or IB is non-zero. 

S = Sum of digits in quotient. 
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Divide Instruction 



PROGRAMMING HINTS 



Overlapped Operands 



Division by Zero 



In case of overlapped operands, the result is unspecified 



An attempt to divide by zero causes Condition Code 4 to be 
set (indicating overflow). The value of the dividend is 
unchanged. 



Preventing Overflow 



Overflow will only occur if the absolute value in the 
leftmost LA positions of the dividend equals or exceeds the 
absolute value of the divisor. In cases where it is 
necessary to accommodate the widest possible range of data, 
including division by 1 , the leftmost LA positions of the 
dividend should contain zero. 
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EDIT INSTRUCTION 



The Edit instruction moves a 1-100 digit numerical field 
into a "control" field so that the information is in a form 
suitable for printing. The control field governs the 
suppression of preceding zeros (including the insertion of 
check protection characters ahead of significant digits), 
the insertion of punctuation marks, and the indication of 
sign. 



INSTRUCTION FIELDS 

Machine Operation Code 

| F Binary 1100 ( 12) . 

Address Specification 

A Address of the leftmost position of Operand-A 

B Address of the leftmost position of Operand-B 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB--Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is 0, A is an address in controlling partition. 

If AC is 1, A is an address in Common. 

BC--If BC is 0, B is an address in controlling partition. 

If BC is 1, B is an address in Common. 



LA— Tens position of length of Operand-A. 
LB--Units position of length of Operand-A, 
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Edit Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2, or 3, the corresponding index register is 

added to A to determine the effective address of Operand-A, 

If AC is 1, the effective address lies in Common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, the corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1, the effective address lies in Common. 



The length of Operand-A is (10)LA+LB. 
If ( 10)LA+LB = 00, the length =100. 

The length of Operand-B is the sum of the following: 

Operand-A length + 1 . 

The number of punctuation characters in Operand-B. 

The number of @ characters in Operand-B. 



OPERATION 

Operand-B, the Control Field 



A filler character is defined as any character other than 
the @sign or a punctuation mark (comma, decimal point, 
hyphen, slash). 

Minimally, a control field consists of as many filler 
characters as there are digits in Operand-A plus one 
trailing character to show sign. In addition, the filler 
characters may be freely interspersed with punctuation 
characters (comma, period, hyphen, slash) and@signs. 

Since the Edit instruction destroys the control field, the 
programmer normally moves the control field to the Operand- 
B address before each use of the Edit instruction. 
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Edit Instruction 



The filler characters designate 
which Operand-A digits can be 
from Operand-A simply replace 
positions in the control 
corresponding to non-significant 
replaced, they are undisturb 
suppression of preceding zeros 
are preset to contain blank char 
protection characters ahead of 
the filler positions are pre 
character such as asterisk). 
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The punctuation characters are used to punctuate the 
significant information received from Operand-A. At the 
completion of the Edit instruction, any punctuation 
characters which find themselves embedded in the 
significant portion of the control field remain undisturbed 
by the operation and thus show the desired punctuation. 
Any punctuation character to the left of the significant 
portion of the control field will have been replaced by the 
neighboring character on the left and thus wiped out. A 
control field should not begin with a punctuation 
character . 

The @ sign is used to insert blank characters between 
filler positions. Execution of the Edit instruction 
replaces each @sign in the mask with a blank character. 

The rightmost position of the control field is used to show 
the sign of Operand-A. Ordinarily, the programmer presets 
the position to contain a hyphen or some other character to 
indicate minus. If Operand-A is negative, the minus 
character remains. If Operand-A is zero or positive, the 
minus character is overwritten with a blank character. 



Execution of Edit Instruction 



The Edit instruction begins by extracting the leftmost 
digit of Operand-A and by finding the leftmost filler 
character in the control field. During the hunt for the 
filler character, any intervening @ sign in the control 
field is replaced by a blank character, and any intervening 
punctuation mark is replaced by the neighboring character 
on the left. 

If the Operand-A digit is significant, the numeric portion 
is put into the filler position of the control field, and 
the zone bits of that position are set to 0/1 to insure 
that the position will print as a numerical value. 

If the digit is non-significant zero, but the filler 
character is 0, the digit is stored in the filler position 
as a significant zero (as are any to the right of it in 
Operand-A) . 
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Edit Instruction 



Condition Codes 



If the digit is non-significant, the 
left undisturbed. 



filler character is 



The process is repeated using the next digit to the right 
in Operand-A and the next filler character in the control 
field. Once a significant digit has been moved from 
Operand-A into the control field, any punctuation mark to 
the right of it is allowed to stand and is not replaced by 
its left-hand neighbor. 

The process continues until the rightmost digit in Operand- 
A and the rightmost filler character of the control field 
have been dealt with. The Condition Code is set. If 
Operand-A contains a positive value or zero, a blank 
character is set in the sign position of the control field 
(the position just to the right of the rightmost filler 
character) . 



After completion of the Edit instruction 

1 Negative, non-zero Operand-A. 

2 Zero Operand-A. 

3 Positive, non-zero Operand-A. 

An overflow condition is not possible. 
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Edit Instruction 



Execution Time (T) in Microseconds 



11.1 + 10.0 (LA + LB) + 6.67 
2.22 (X3) + 2.22 (XI) + TIX 



(X1 ) + 3.33 (X2) + 



Key X1 = Number of V signs in control field plus 
number of periods ( . ) , commas ( , ) , slash 
(/), and minus (-) signs before signifi- 
cance in Operand-B control field. 

X2 = Number of periods ( . ) , commas ( , ) , slash (/) , 
and minus (-) signs after significance in 
Operand-B control field. 

X3 = Number of significant digits in Operand-A. 

XI = for a negative operand. 
1 for a positive operand. 

TIX = 0.0, if IA and IB are both zero. 
TIX =58.9, if IA and IB are both non-zero. 
TIX = 3 1 . 1 , if IA or IB is non-zero. 
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Edit Instruction 



EXAMPLES 

Printing Social Security Numbers 



Operand-A 
Operand-B 
Operand-B 



Check Protection 



Use of Commas 



Operand-A 
Operand-B 
Operand-B 



Operand-A 
Operand-B 
Operand-B 



098144159 

000-00-0000- 

098-14-4159 



0000001234 
**,***,***. 00- 
******** 1 2 . 34 



1234567890 
bb,bbb,bbb.0 
12,345,678.90 



before editing 
after editing 



before editing 
after editing 



before editing 
after editing 



Note b is here used to represent a blank character 

Suppressing Preceding Zeros 



Operand-A 
Operand-B 
Operand-B 



0000012345 
bb,bbb,bbb.0 0- 
bbbbbbb12 3.4 5 



before editing 
after editing 



Note b is here used to represent a blank character 
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EXCHANGE INSTRUCTION 



The Exchange instruction interchanges the characters in two 
fields of equal length in main memory. Each field can 
comprise 1 - 100 characters. 



INSTRUCTION FIELDS 

Machine Operation Code 

I F Binary 1111 ( 15) . 

Address Specification 

A Address of the leftmost position of Operand-A. 

B Address of the leftmost position of Operand-B. 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB — Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is 0, A is an address in controlling partition. 

If AC is 1 , A is an address in Common. 

BC--If BC is 0, B is an address in controlling partition. 

If BC is 1, B is an address in Common. 



LA--Tens position of length of both Operand-A and Operand- 
B. 

LB — Units position of length of both Operand-A and Operand- 
B. 
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Exchange Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2, or 3, the corresponding index register is 

added to A to determine the effective address of Operand-A, 

If AC is 1, the effective address lies in Common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, the corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1, the effective address lies in Common. 



Operand-A and Operand-B are equal in length. 

10LA + LB = Lengths of operands for Move Character 

instruction. 

If 10LA + LB = 00, 100 is the length of the operands 



OPERATION 

General Description 



Condition Code 



The leftmost character of Operand-B is extracted and held 
temporarily in a register. The character in the leftmost 
position of Operand-A is moved to the leftmost position in 
Operand-B, and the character in the register is then stored 
in the leftmost position of Operand-A. This operation is 
repeated from left to right until the entire fields have 
been interchanged. 



| 2, after completion of the Exchange instruction. 
Execution Time (T) in Microseconds 

T= 38.9 + 13.3 (10LA + LB) + TIX. 
Key: 



TIX = 0.0 
TIX =58.9 
TIX =31.1 



if IA and IB are both zero 

if IA and IB are both non-zero 

if IA or IB is non-zero. 
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Exchange Instruction 



PROGRAMMING HINTS 



If Operand-A and Operand-B 
exchange occurs. 



do not overlap, a simple 



If Operand-A and Operand-B overlap each other, the 
programmer can predict the result for any particular case 
by mentally stepping through the operation as described in 
"General Description" above. 

NOTE Using an overlapped exchange instruction can be 

useful for rotating characters of a field. If 
Operand-A and Operand-B overlap for all but one 
character, then each time the exchange instruction 
is executed the leftmost character moves to the 
rightmost position, and all other characters move 
one position to the left. 
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Exchange Instruction 



(This page intentionally left blank) 
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FORM NUMERIC 



The Form Numeric instruction moves numeric information from 
a 1-10 position mixed field to a second 1-10 position 
field. After the operation, the second field is of the 
numerical form normally used for arithmetic operations. 



INSTRUCTION FIELDS 

Machine Operation Code 

| F Binary 110 1 ( 13 ) . 

Address Specification 

A Address of the leftmost position of Operand-A. 

B Address of the leftmost position of Operand-B. 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB--Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is 0, A is an address in controlling partition. 

If AC is 1, A is an address in Common. 

BC — If BC is 0, B is an address in controlling partition. 

If BD is 1, B is an address in Common. 



LA--Length of Operand-A. 
LB--Length of Operand-B. 
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Form Numeric Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B- Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2 , or 3 , the corresponding index register is 

added to A to determine the effective address of Operand-A. 

If AC is 1, the effective address lies in Common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, the corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1, the effective address lies in Common. 



If LA is 0, the length of Operand-A is 10 characters. 
If LA is 1 thru 9, the length of Operand-A is 1 thru 9 
characters . 

If LB is 0, the length of Operand-B is 10 characters. 
If LB is 1 thru 9, the length of Operand-B is 1 thru 9 
characters . 



OPERATION 

Execution of Form Numeric Instruction 



Execution begins with a right-to-left search for the 
rightmost digit in Operand-A and a determination of its 
sign: 

If the rightmost non-blank character is a digit, it 

is moved unchanged into the rightmost position of 
Operand-B. The sign of Operand-B is positive. 

If the rightmost non-blank character is one of the 

characters P thru Y, it is considered to be a digit 
with a minus sign. It is moved unchanged into the 
rightmost position of Operand-B. The sign of 
Operand-B is negative. 

If the rightmost non-blank character is a hyphen 

(minus sign) , the rightmost digit is converted to 
the corresponding character P thru Y (i.e., bit-7 
is set ON) and is stored in the rightmost position 
of Operand-B. The sign of Operand-B is negative. 
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If the rightmost non-blank character is none of the 

above, it is skipped over and the rightmost digit 
is moved unchanged into the rightmost position of 
Operand-B. The sign of Operand-B is positive. 

Once the rightmost digit is selected from Operand-A and is 
moved into Operand-B, the process continues from right to 
left. The next digit to the left is found in Operand-A and 
is moved unchanged into the next left position of Operand- 
B. Intervening characters which are not digits are simply 
passed over and are not moved. 

If a digit is moved into the leftmost position of Operand- 
B and there are yet unmoved digits in Operand-A, the 
operation is abandoned and Condition Code 4 is set to show 
the overflow condition. 

When the leftmost digit of Operand-A is moved into an 
Operand-B position, any unfilled positions in Operand-B are 
set to zero and the operation is finished. 

If Operand-A consists entirely of blank characters, no 
digits can be moved. In this case, Operand-B is set to 
zero in all positions. 

Condition Codes 



After completion of the Form Numeric instruction. 

1 = Negative, non-zero Operand-B. 

2 = Zero Operand-B. 

3 = Positive, non-zero Operand-B. 

4 = Overflow. 



Execution Time (T) in Microseconds 



T=43.3 + 3.33 (LA) + 7.78 (LB) + 2.22 (Z) + TIX, 
if LA - Z is equal to or less than LB. 

T = 45.55 + 1.11 (LA) + 10.0 (LB) + 4.44 (Z') + TIX, 

if LA - Z is greater than LB, causing an improper 
overflow. 

Key Z = Number of non-numeric characters in Operand-A. 

Z 1 = Number of non-numeric characters encountered i 
Operand-A before LB is filled. 

TIX = 0.0, if IA and IB are both zero. 
TIX =58.9, if IA and IB are both non-zero. 
TIX =31.1, if IA or IB is non-zero. 
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Form Numeric Instruction 
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MOVE CHARACTER INSTRUCTION 



The Move Character instruction moves 1-100 characters from 
one location in main memory to another. 



INSTRUCTION FIELDS 

Machine Operation Code 

| F Binary 1000 (8 ) . 

Address Specification 

A Address of the leftmost position of Operand-A, 

B Address of the leftmost position of Operand-B 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB--Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is 0, A is an address in controlling partition. 

If AC is 1, A is an address in Common. 

BC--If BC is 0, B is an address in controlling partition. 

If BC is 1, B is an address in Common. 



LA--Tens position of length of both Operand-A and Operand- 
B. 

LB--Units position of length of both Operand-A and Operand- 
B. 
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Move Character Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2, or 3, the corresponding index register is 

added to A to determine the effective address of Operand-A. 

If AC is 1, the effective address lies in Common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, the corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1, the effective address lies in Common. 



Operand-A and Operand-B are egual in length. 

10LA + LB Length of operands for Move Character 

instruction . 

If 10LA + LB 00, 100 is the length of the operands 



OPERATION 

General Description 



Condition Code 



Operand-A is copied into Operand-B, one position at a time, 
from left to right, starting with the leftmost position of 
Operand-A and writing it into the leftmost position of 
Operand-B . 



I 2, after completion of the Move Character instruction. 
Execution Time (T) in Microseconds 

T=40.0 + 11.K10LA + LB) + TIX 

Key: TIX =0.0 if IA and IB are both zero 

TIX =58.9 if IA and IB are both non-zero 
TIX =31.1 if IA or IB is non-zero 
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PROGRAMMING HINTS 

Move Character VS Move Numeric 



The Move Character instruction is similar to the Move 
Numeric instruction. The Move Numeric instruction will 
extract and copy only the numeric portion of a character 
(leaving the zone bits unchanged); the Move Character 
instruction will copy an entire character including both 
numeric and zone portions. 



Overlapping Operands 



If Operand-A and Operand-B do not overlap, then Operand-A 
is unchanged by the Move Character instruction. 

To shift the Operand-A data field one or more positions to 
the left (to a lower machine address) the Move Character 
instruction can be used when the operands overlap if the 
Operand-B address is not greater than the Operand-A 
address. Only the unlapped positions of Operand-A will be 
unchanged . 

To propagate a given character throughout a data field, put 
the character into the leftmost position of the field, and 
use the Move Character instruction as follows: 

Operand-A address is the address of the data field. 
Operand-B address is the address of the data field + 1 . 
Operand length must be 1 less than the data field 
length. 
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Move Character Instruction 
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MOVE NUMERIC INSTRUCTION 



The Move Numeric instruction moves the numeric portion of 
1-100 characters from one location in main memory to 
another. The zone bits of both fields are unchanged. 



INSTRUCTION FIELDS 

Machine Operation Code 

| F Binary 1001 (9) 

Address Specification 



A Address of the leftmost position of Operand-A, 

B Address of the leftmost position of Operand-B 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB--Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is O, A is an address in controlling partition 

If AC is 1, A is an address in Common. 

BC--If BC is 0, B is an address in controlling partition 

If BC is 1, B is an address in Common. 



LA--Tens position of length of both Operand-A and Operand- 
B. 

LB--Units position of length of both Operand-A and Operand- 
B. 
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Move Numeric Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2, or 3, the corresponding index register is 

added to A to determine the effective address of Operand-A, 

If AC is 1, the effective address lies in common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, the corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1, the effective address lies in common. 



Operand-A and Operand-B are equal in length. 

10LA + LB = Length of operands for Move Numeric 

instruction . 

If 10LA + LB = 00, 100 is the length of the operands 



OPERATION 

General Description 



Condition Code 



The numeric portion of Operand-A is copied into the numeric 
portion of Operand-B, one position at a time, from left to 
right, starting with the leftmost position of Operand-A and 
writing it into the leftmost position of Operand-B. 



I 2, after completion of the Move Numeric instruction. 
Execution Time (T) in Microseconds 

T 40.0 + 11.K10LA + LB) + TIX 

Key: TIX = 0.0 ifIA and IB are both zero 

TIX =58.9 if IA and IB are both non-zero 
TIX =31.1 if IA or IB is non-zero. 
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PROGRAMMING HINTS 

Move Numeric VS Move Character 



The Move Numeric instruction is similar to the Move 
Character instruction. The Move Numeric instruction will 
extract and copy only the numeric portion of a character 
(leaving the zone bits unchanged); the Move Character 
instruction will copy an entire character including both 
numeric and zone portions. 



Overlapping Operands 



If Operand-A and Operand-B do not overlap, then Operand-A 
is unchanged by the Move Numeric instruction. 

To shift the Operand-A numeric field one or more positions 
to the left (to a lower machine address) the Move Numeric 
instruction can be used when the operands over-lap if the 
Operand-B address is not greater than the Operand-A 
address. The unlapped positions of Operand-A and all zone 
bits in both operands will be unchanged. 

To propagate a given digit throughout a data field, put the 
digit into the leftmost position of the field, and use the 
Move Numeric instruction as follows: 

Operand-A address is the address of the data field. 
Operand-B address is the address of the data field + 1 . 
Operand length must be 1 less than the data field 
length. 

The Move Numeric instruction enables the programmer to 
change the numeric portions of instructions. If is most 
freguently used in address modification (A and B fields). 
It is also useful in varying the LA and/or LB fields. 
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MULTIPLY INSTRUCTION 



The Multiply instruction computes the algebraic product of 
two 1 to 1 position numeric operands. 



INSTRUCTION FIELDS 

Machine Operation Code 

| F Binary 110 (6 ) 

Address Specification 



A Address of the leftmost position of Operand-A. 

B Address of the leftmost position of Operand-B, and 

Address of the leftmost position of Product field. 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB--Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is 0, A is an address in controlling partition 

If AC is 1, A is an address in Common. 

BC--If BC is 0, B is an address in controlling partition 

If BC is 1, B is an address in Common. 



LA--Length of Operand-A. 
LB--Length of Operand-B. 
LB + LA--Length of Product field 
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Multiply Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2, or 3, the corresponding index register is 

added to A to determine the effective address of Operand-A 

If AC is 1, the effective address lies in Common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, the corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1, the effective address lies in Common. 



If LA is 0, the length of Operand-A is 10 characters. 
If LA is 1 thru 9, the length of Operand-A is 1 thru 9 
characters . 

If LB is 0, the length of Operand-B is 10 characters. 
If LB is 1 thru 9, the length of Operand-B is 1 thru 9 
characters . 



PRODUCT FIELD 



The product field may be thought of as the multiplier field 
(Operand-B) with a rightward extension of a length equal to 
that of the multiplicand (Operand-A); hence, the product 
field will be located at the Operand-B address and will 
have the length LB + LA. 



OPERATION 

General Description 



Operand-A is the multiplicand. 
Operand-B is the multiplier. 
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Multiply Instruction 



Condition Codes 



The product is developed in the extended Operand-B field. 
The extension is cleared to zeros before the following 
computation is begun: 

1 The rightmost digit of the multiplier is put into 

a register to govern the number of times the 
multiplicand will be added into the rightmost 
positions of the product field. 

2 The rightmost position of the multiplier field is 

cleared to provide an extra left position for the 
add operation. 

3 The multiplicand is added into the rightmost 

positions of the product field the number of times 
specified by the governing multiplier digit stored 
in the register. 

4 Steps 1, 2, and 3 are repeated with the next left 

digit of the multiplier acting as governing digit. 
The multiplicand is repeatedly added into the next 
left positions of the product field. The process 
continues until the leftmost multiplier digit has 
served as governing digit. 

Bit-7 is set OFF in all positions of the product except the 
rightmost position which is set to the sign of the product. 

Bit-7 ON = factor signs differed. 

Bit-7 OFF = factor signs were alike. 

Bit-5 is set ON in all positions of the product field. 

Operand-A is unchanged by the multiply operation if the 
fields do not overlap. 

An overflow condition will never occur if the numeric 
portions of the numeric values are thru 9. 



After completion of the Multiply instruction: 

1= Negative, non-zero product. 

2 = Zero product. 

3 = Positive, non-zero product. 
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Multiply Instruction 



Execution Time (T) in Microseconds 



T 47.8 + 6.67 (LA )+ 10 
+ TIX. 



(LB) + ( ( 10.0 + 11.1 LA) (S) ) 



Key: TIX = 0.0, if IA and IB are both zero. 

TIX =58.9, if IA and IB are both non-zero 
TIX =31.1, if IA or IB is non-zero. 

S = Sum of digits in Operand-B. 



PROGRAMMING HINTS 

Overlapped Operands 



Overflow 



I In case of overlapped operands, the result is unspecified 



Overflow will never occur if all characters in the numeric 
portions of the operands are the digits thru 9. Overflow 
can occur if the numeric portions of the operands contain 
the following digits: 



binary 



1010 


( 10) 


101 1 


( 11 ) 


1 100 


( 12) 


1101 


( 13) 


1 1 10 


( 14) 


1111 


( 15) 
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READ INSTRUCTION 



READ INSTRUCTION 



The Read instruction moves data from an input device to 
sequential locations in Main Memory. 



INSTRUCTION FIELDS 

Machine Operation Code 

|F Binary 0000 (0) 

Channel Specification 



Mode Specification 



LB--If bit-1 is 0, reading will be routed through the FAC . 
If bit-1 is 1, reading will be routed through the IOC. 



LB--If bit-4 is 0, reading will be in the fill mode. 

If bit-4 is 1, reading will be in the "non-fill" mode 



Input Device Specification 



LA — Device address 0-9 for IOC. 

Device address 0-4 and 8 for FAC. 



Input Address Specification 



A Address of input area. 

B If the input device is not the disc, B is the count. 

If the input device is the disc, B is the indirect 
disc address. 

The indirect disc address points to a 6-character field 
which contains the disc address. The format of this field 
is illustrated in Figure 3. 



Indexing Specification 



IA--Index register for determining effective address of 
input area. 

IB--Index register for determining effective indirect disc 
address or effective count. 
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Read Instruction 



Common Partition Specification 



Count Specification 



AC--If AC is 0, A is an address in controlling partition 

If AC is 1, A is an address in Common . 

BC--If B is a count, the BC is ignored. 

If BC is 0, B is an address in controlling partition 

If BC is 1, B is an address in Common. 



If the disc is the input device, the count is always 100 
and is not specified in the Read instruction. 

If the input device is not the disc, B is the count. A 
count of 0000 is interpreted as 10,000. 



OPERATION 

IOC General Operation 



A Read instru 
the IOC is 
first decoded 
and P for the 
is sent to 
then relinqui 
of the Read 
of instructio 
instruction 
IOC that has 
proceeds as f 



ction that specifies 
executed increment 
, and parameters are 
partition initiatin 
the IOC to alert the 
shed to the next par 
instruction is perfo 
ns in the other 
begins, the CPU sto 
a character ready, 
ollows : 



data transmission through 
ally. The instruction is 

set into registers A, B, 
g the operation. A signal 

input device. Control is 
tition. The fulfillment 
rmed between the execution 
partitions. Before each 
res one character for each 
This incremental operation 



1 An IOC requests a character from the input device. 

2 The input device gives a character to the IOC which 

sets a signal to inform the CPU of "character 
ready" . 

3---Between instruction executions, the CPU discovers 
the signal, stores the character being held by the 
IOC, and updates the parameter registers. 

4 If the number of characters already transmitted has 

reached the count specified in the Read 
instruction, no more characters are requested. If 
the count has not been reached, steps 1, 2, 3, and 
4 are repeated. 
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Read Instruction 



Only the numeric portions (1-4) of each character are used for 
specifying this information. Bit 7 may be either or 1; Bit 5 
must always be 1. The information is specified: as follows. 



Character 



t ft tft t ft 



t 



DEVICE NUMBER (0-9) 



» 



UNITS DIGIT (0-9) OF A 
THREE DIGIT TRACK NUMBER 



HUNDREDS DIGIT (0 or 1) OF 
A THREE DIGIT TRACK NUMBER 



» 



TENS DIGIT (0-9) OF A 
TWO DIGIT SECTOR NUMBER 



* 



TENS DIGIT (0-9) OF A 
THREE DIGIT TRACK NUMBER 



UNITS DIGIT (0-9) OF A 
TWO DIGIT SECTOR NUMBER 



» 



ARM NUMBER (0-4) 



NOTE: 



•The bits in characters 1,3,4,5, and 6 have the following values: 

Bit 1 has the value 1 when it is ON. 

Bit 2 has the value 2 when it is ON. 

Bit 3 has the value 4 when it is ON. 

Bit 4 has the value 8 when it is ON. 

• The bits in character 2 have the following values: 

Bit 1 has the value 1 when it is ON. 

Bit 2 has the value 1 when it is ON. 

Bit 3 has the value 2 when it is ON. 

Bit 4 has the value 4 when it is ON. 

Figure 3 Disc Address Matrix Format 
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Read Instruction 



If control returns to the partition which initiated the 
Read instruction before the count is satisfied, control 
simply passes to the next partition. If the count is 
satisfied when control returns to the partition which 
initiated the Read instruction, a Condition Code is set 
(see description of individual devices), the execution 
continues with the next sequential instruction following 
the Read instruction. 



FAC General Operation 



A Read instruction that specifies data transmission through 
the FAC does not relinquish control to the next partition 
during data transmission. Instead, the CPU is devoted 
exclusively to storing data provided by the FAC until the 
entire count is satisfied. During this period the CPU does 
not service any IOC. Service to the IOCs resumes at the 
completion of the Read instruction. 



Disc Access Sequence 



A Read instruction addressing the disc does not typically 
pre-empt the CPU (as described above) immediately. It is 
sometimes necessary to wait until the disc is free, and 
then to wait while the heads move to the required cylinder. 
During either type of wait, control passes to the 
neighboring partition, and returns again in normal 
sequence . 

A disc is free if it is not bound to another partition. It 
is bound to a given partition as soon as the partition 

remains 



institutes a seek upon it; 
transmission is complete. 



it 



bound until data 



If the disc is bound to another partition when a Read 
instruction is attempted, control merely passes to the next 
partition. The Read instruction will be attempted again 
when control returns to the host partition. 

If the disc is free when a Read instruction is attempted, 
a seek is automatically instituted, and the disc is then 
bound to the host partition. If head movement is 
necessary, control passes to the next partition. 
Transmission begins when the heads reach the proper 
cylinder, when control returns to the host partition, and 
when the desired sector rotates into place. 

If the heads are already "on cylinder" when the seek is 
instituted, control remains with the host partition. 
Transmission begins as soon as the desired sector rotates 
into place. 
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Read Instruction 



When the disc record is entirely transmitted, a Condition 
Code is set to indicate the outcome. The CPU services any 
outstanding IOC for signals, and execution continues with 
the next seguential instruction following the Read 
instruction . 

Succeeding instructions in the host partition which access 
the same cylinder will be executed without switching 
partitions. The first attempt to access another cylinder, 
however, will free the disc and pass control to the next 
partition. When control again returns to the host 
partition, the Read/Write instruction will be subject to 
the entire wait process (as described above). 



Fill and Non-Fill 



A Read instruction using the IOC will terminate prematurely 
if the input device sends the IOC a Unit Separator 
character. In such a case, the Unit Separator character is 
not stored. Remaining positions of the input area are 
normally filled with blank characters. If the non-fill 
option was requested (bit-4 of instruction field LB), the 
remaining positions in the input area are left undisturbed. 



Condition Codes 



After completion of the Read instruction. 

1 = Error 

2 = Normal 

3 =Flag 

4 = Fault 

Execution Time (T) in Microseconds 

T - 91.1 + TIX for an Input/Output Channel (IOC). 

T=73.3 + TIX for a File Access Channel (FAC). 

Key: TIX = 0.0, if IA and IB are both zero. 

TIX = 58.9, if IA and IB are both non-zero. 
TIX = 31.1, if IA or IB is non-zero. 
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Read Instruction 



(This page intentionally left blank) 
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SUBTRACT INSTRUCTION 



SUBTRACT INSTRUCTION 



The Subtract instruction computes the algebraic difference 
between the numeric portions of the two operands. The 
difference replaces the second operand (the minuend) and 
leaves the first operand unchanged if the fields do not 
overlap. 



INSTRUCTION FIELDS 



Machine Operation Code 

| F Binary 0111 (7) . 

Address Specification 

A Address of the leftmost position of Operand-A 

B Address of the leftmost position of Operand-B 



Indexing Specification 



IA--Index register for determining effective address of 
Operand-A. 

IB--Index register for determining effective address of 
Operand-B . 



Common Partition Specification 



Length Specification 



AC--If AC is 0, A is address in controlling partition. 

If AC is 1, A is address in Common. 

BC--If BC is 0, B is address in controlling partition. 

If BC is 1, B is address in Common. 



LA--Length of Operand-A. 
LB--Length of Operand-B. 
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Subtract Instruction 



OPERAND FIELDS 

Operand-A Address 



Operand-B Address 



Operand Lengths 



If IA is 0, then A is the effective address. 

If IA is 1, 2, or 3, the corresponding index register is 

added to A to determine the effective address of Operand-A, 

If AC is 1, the effective address lies in Common. 



If IB is 0, then B is the effective address. 

If IB is 1, 2, or 3, the corresponding index register is 

added to B to determine the effective address of Operand-B 

If BC is 1, the effective address lies in Common. 



If LA is 0, the length of Operand-A is 10 characters. 

If LA is 1 thru 9, the length of Operand-A is 1 thru 9 
characters . 

If LB is 0, the length of Operand-B is 10 characters. 

If LB is 1 thru 9, the length of Operand-B is 1 thru 9 
characters . 
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Subtract Instruction 



OPERATION 



General Description 



Condition Codes 



The subtract operation proceeds from right to left starting 
with the rightmost character of Operand-A and Operand-B. 
Charaster by character, the algebraic difference is 
developed in Operand-B. 

The hardware acts as though the sign of Operand-A were 
reversed. In every other respect the instruction behaves 
like the Add instruction. 

If Operand-A is shorter than Operand-B, the operation 
proceeds normally until Operand-A is exhausted. After 
that, the process continues in similar fashion except that 
a zero character is automatically substituted every time 
the logic calls for a character from Operand-A. In effect, 
Operand-A is given enough preceding zeros to make it the 
same length as Operand-B. 

If Operand-A is longer than Operand-B, subtraction stops 
after the leftmost position in Operand-B has been 
subtracted. The remaining positions in Operand-A are 
ignored, and do not affect the difference or the Condition 
Code. 

The algebraic sign of the difference is placed in bit-7 of 
the rightmost position of Operand-B, and bit-5 is turned 
on. Except for the rightmost character, the other zone 
bits of Operand-B are unchanged. Operand-A is unchanged by 
the subtract operation. 

If the difference exceeds the capacity of Operand-B, a 
carry-to-the-lef t from the leftmost position does not 
occur. Condition Code 4 is set to indicate the overflow. 



After completion of the Subtract instruction 

1= Negative, non-zero difference. 
2 = Zero difference. 
3= Positive, non-zero difference. 
4 = Overflow. 
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Subtract Instruction 



Execution Time (T) in Microseconds 



T =42.2 + 3.3 (LA) + 10.0 
to or less than LB. 



(LB) + TIX + TOD, if LA is equal 



T =42.2 + 11 (LA) + 12.2 (LB) + TIX + TOD, if LA is 
greater than LB. 

Key: TIX = 0.0, if IA and IB are both zero. 

TIX =58.9, if IA and IB are both non-zero. 
TIX =31.1, if I A or IB is non-zero. 

TOD = 0.0, if an overdraft does not occur. 

TOD = 1 . (LB), if an overdraft occurs. 

An overdraft will always occur when the absolute 

value of Operand-A exceeds the absolute value of 

Operand-B and they have like signs. 



PROGRAMMING HINTS 

Overlapped Operands 



| In case of overlapped operands, the result is unspecified 
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WRITE INSTRUCTION 



WRITE INSTRUCTION 



The Write instruction transmits data from sequential 
locations in Main Memory to an output device. A control 
option enables the Write instruction to communicate control 
information to the input or output device. 



INSTRUCTION FIELDS 

Machine Operation Code 

| F Binary 0001 ( 1 ) 

Channel Specification 



LB--If bit-1 is 0, writing will be routed through the FAC. 
If bit-1 is 1, writing will be routed through the IOC. 



Write Control Specification 



LB--If bit-2 is 0, normal write. 
If bit-2 is 1 , write control 



Output Device Specification 



LA--Device address 
Device address 



9 for IOC. 

4 and 8 for FAC 



Output Address Specification 



A Address of output area. 

B If the output device is not the disc, B is the count. 

If the output device is the disc, B is the indirect disc 
address . 

The indirect disc address points to a 6-character field 
which contains the disc address. The format of this 
field is illustrated in Figure 4. 



Indexing Specification 



IA--Index register for determining effective address of 
output area. 

IB--Index register for determining effective indirect disc 
address or effective count. 
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Write Instruction 



Common Partition Specification 



Count Specification 



AC--If AC is 0, A is an address in controlling partition 

If AC is 1 , A is an address in Common. 

BC--If B is a count, BC is ignored. 

If BC is 0, B is an address in controlling partition 

If BC is 1 , B is an address in Common. 



If the disc is the output device, the count is always 100 
and is not specified in the Write instruction. 

If the output device is not the disc, B is the count. A 
count of 0000 is interpreted as 10,000. 



OPERATION 

IOC General Operation 



A Write instruction 
through the IOC is execu 
is first decoded, and pa 
B, and P for the par 
signal is sent to the I 
Control is then relin 
transmission of characte 
instructions in the 
instruction begins, the 
which is ready to accept 
proceeds as follows: 



that specifies data transmission 
ted incrementally. The instruction 
rameters are set into registers A, 
tition initiating the operation. A 
OC to alert the output device, 
quished to the next partition. The 
rs occurs between the execution of 
other partitions. Before each 
CPU sends one character to each IOC 

one. This incremental operation 



1 The IOC sets a signal to inform the CPU that it is 

ready to accept a character from the output area. 

2 Between instruction executions, the CPU discovers 

the signal and checks the count balance. If the 
count has been reached, no more characters are sent 
to the IOC. If the count has not been reached, 
steps 3, 4, 1, and 2 are repeated, in that order. 

3 The CPU gives a character to the IOC and updates 

the parameter registers. 

4 As soon as it can, the output device accepts the 

character „ 
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Write Instruction 



Only the numeric portions (1-4) of each character are used for 
specifying this information. Bit 7 may be either or 1 *, Bit 5 
must always be 1. The information is specified as follows. 



Character 


1 


2 * 


3 


4 


5 


« 








- 




D 


A 


T 


T 


S 


s 







A 


T 


T 


S 


s 




D 


A 


T 


T 


s 


s 




D 


T 


T 


T 


s 


s 



tt ttft^ 



B: 



t 



DEVICE NUMBER (0-9) 



* 



UNITS DIGIT (0-9) OF A 
THREE DIGIT TRACK NUMBER 



* 



HUNDREDS DIGIT (0 or 1) OF 
A THREE DIGIT TRACK NUMBER 



* 



TENS DIGIT (0-9) OF A 
TWO DIGIT SECTOR NUMBER 



» 



TENS DIGIT (0-9) OF A 
THREE DIGIT TRACK NUMBER 



* 



1 UNITS DIGIT (0-9) OF A 
TWO DIGIT SECTOR NUMBER 



ARM NUMBER (0-4) 



NOTE: 



•The bits in characters 1,3,4,5, and 6 have the following values: 

Bit 1 has the value 1 when it is ON. 

Bit 2 has the value 2 when it is ON. 

Bit 3 has the value 4 when it is ON. 

Bit 4 has the value 8 when it is ON. 

• The bits in character 2 have the following values: 

Bit 1 has the value 1 when it is ON. 

Bit 2 has the value 1 when it is ON. 

Bit 3 has the value 2 when it is ON. 

Bit 4 has the value 4 when it is ON. 



Figure 4 Disc Address Matrix Format 



4/73 



CPU Instructions Reference Manual 61 



Write Instruction 



If control returns to the partition which initiated the 
Write instruction before the count is satisfied, control 
simply passes to the next partition. If the count is 
satisfied when control returns to the partition which 
initiated the Write instruction, a Condition Code is set 
(see description of individual devices), and execution 
continues with the next sequential instruction following 
the Write instruction. 



FAC General Operation 



A Write instruction that specifies data transmission 
through the FAC does not relinquish control to the next 
partition during data transmission. Instead, the CPU is 
devoted exclusively to feeding data to the FAC until the 
entire count is satisfied. During this period the CPU does 
not service any IOC. Service to the IOCs resumes at the 
completion of the Write instruction. 



Disc Access Sequence 



A Write instruction addressing the disc does not typically 
pre-empt the CPU (as described above) immediately. It is 
sometimes necessary to wait until the disc is free, and 
then to wait while the heads move to the required cylinder. 
During either type of wait, control passes to the 
neighboring partition, and returns again in normal 
sequence. 

A disc is free if it is not bound to another partition. It 
is bound to a given partition as soon as the partition 
institutes a seek upon it; it remains bound until data 
transmission is complete. 

If the disc is bound to another partition when a Write 
instruction is attempted, control merely passes to the next 
partition. The Write instruction will be attempted again 
when control returns to the host partition. 

If the disc is free when a Write instruction is attempted, 
a seek is automatically instituted, and the disc becomes 
bound to the host partition. If head movement is 
necessary, control passes to the next partition. 
Transmission begins when the heads reach the proper 
cylinder, when control returns to the host partition, and 
when the desired sector rotates into place. 

If the heads are already "on cylinder" when the seek is 
instituted, control remains with the host partition. 
Transmission begins as soon as the desired sector rotates 
into place. 
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Write Instruction 



When the disc record is entirely transmitted, a Condition 
Code is set to indicate the outcome. The CPU services any 
outstanding IOC signals, and execution continues with the 
next sequential instruction following the Write 
instruction . 

Succeeding instructions in the host partition which access 
the same cylinder will be executed without switching 
partitions. The first attempt to access another cylinder, 
however, will free the disc and pass control to the next 
partition. When control again returns to the host 
partition, the Write instruction will be subject to the 
entire wait process (as described above). 



Write Control Mode 



A Write instruction may specify the transmissio 
characters to the external input/output devi 
bit-2 of the LB instruction field ON. The inf 
the output area is sent to the external 
character at a time and exerts a controlling e 
particular effect depends upon the information 
and upon the external device. As soon a 
character is accepted by the external dev 
execution is free to continue even though the 
effect is not yet realized. On the opposi 
table showing how each internal character is c 
external form by an IOC Write Control instructi 



n of con 


trol 


ce by having 


ormation 


in 


device 


one 


f feet . 


The 


transmi 


tted 


s the 


last 


ice, pro 


gram 


controlling 


te page 


is a 


onverted 


to 


on . 





Condition Codes 



After completion of the Write instruction. 

1 = Error 

2 = Normal 

3 = Flag 

4 = Fault 

Execution Time (T) in Microseconds 

T=91.1 + TIX for an Input/Output Channel (IOC). 

T=73.3 + TIX for a File Access Channel (FAC). 

Key: TIX = 0.0, if IA and IB are both zero. 

TIX =58.9, if IA and IB are both non-zero 
TIX = 31 . 1 , if IA or IB is non-zero. 
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Write Instruction 





Same Characters 


Changed Characters 




Internal 


External 


Internal 


External 


7 O 

Bits 


O 


1 


O 


6 


1 




o 




SP 


SP 





NUL 




i 


1 


A 


SOH 




ii 


II 


B 


STX 




# 


# 


C 


ETX 




$ 


$ 


D 


EOT 




% 


% 


E 


ENQ 




& 


& 


F 


ACK 




i 


1 


G 


BEL 




( 


( 


H 


BS 




) 


) 


I 


HT 




* 


* 


J 


LF 




+ 


+ 


K 


VT 




9 


> 


L 


FF 




- 


- 


M 


CR 




. 


. 


N 


SO 




/ 


/ 





SI 










P 


DLE 




1 


1 





DC1 




2 


2 


R 


DC2 




3 


3 


S 


DC3 




4 


4 


T 


DC4 




5 


5 


U 


NAK 




6 


6 


V 


SYB 




7 


7 


W 


ETB 




8 


8 


X 


CAN 




9 


9 


Y 


EM 




: 




Z 


SUB 




» 


» 


{ 


ESC 




< 


< 


\ 


FS 




= 


= 


} 


GS 




> 


> 


* 


RS 




? 


? 





US 



Table 4 Write Control Conversions 
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